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(57) Abstract: A customizable browser framework configured to simplify the task of generating application-specific, user-specific, 
and location-specific browser user interfaces is disclosed- The browser may be configured for execution on a specialized browser, or 
on a generic personal computer. Upon power-up or user login, the browser is configured to access a configuration file. The configura- 
tion file may be locked to prevent user access, and may stored locally or on a server. The browser is configured to use the information 
stored in the configuration file to generate a user interface that may have one or more of the following features: customizable icons 
and links, plug-ins, and persistent portals. The configuration file may include position information, size information, and linking 
information for one or more graphics files that are usable to generate the icons and other user interface features. The configuration 
file may be automatically updated from a remote server based on a predetermined update schedule and based on when the appliance 
is in an idle state. 
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TITLE: PERSISTENT PORTAL FOR A BROWSER 



5 Background of the Inyention 

L Field of the Invention 

The present invention generally relates to network browsers and graphical user interfaces. More 
paiticialarly, the present invention relates to systems and methods for custonaizing graphical user interfaces. 

10 

2. Description of the Related Art 

The Internet is an important resource for reference, research, browsing, online shopping, and e-mail. The 
Internet provides worldwide access to materials in a variety of subject areas. As used herein, the "Intemet" is a 
decentralized global network connecting a large number of computers through standard communication and data 

15 protocols. One of the most well-known aspects of the Internet is the World Wide Web. As used herein, the "World 
Wide Web" is a plurality of web pages interconnected by a set of hypertext links and accessible to computers on the 
Internet. As used herein, a 'Veb page" may include an information-bearing document or application which is 
accessible on the World Wide Web. Web pages may also include graphics and data files containing images, video 
clips, three-dimensional graphics, and audio information. A group of web pages sharing a particular address may 

20 be collectively referred to as a "web site". 

Information accessible via the Internet such as web pages are typically accessed using a browser. A 
browser is typically a software application that generates a graphical user interface so that a user may access the 
information in a user-friendly manner. A number of different browsers are cuirently available, e.g., Microsoft's 
Internet Explorer, Netscape's Navigator, and Opera from Opera Software. 

25 Browsers have contributed to the recent growth in popularity of the Internet much in the same way that 

graphical user interfaces have contributed to the increased popularity of personal computers. The graphical user 
interface of browsers have allowed more people to access Ihe Internet without specialized training and have 
spawned a deluge of new applications, including electronic banking and stock trading, interactive news, and online 
shopping. As web usage increases and as new users, unfamiliar with computers wish to use the Internet, a new 

30 trend toward Intemet appliances has begun. Internet appliances is a term used to refer to any simplified computer 
or apphance that may be used to access the Intemet and/or perform other networked functions. Thus, Intemet 
appliances are also sometimes referred to as network apphances. In their first generation form, most Intemet 
appliances are inexpensive limited-purpose personal computers. They typically have displays, keyboards, 
touchpads, and other input devices, but they may not have all of the processing power or peripherals that a tradition 

35 personal computer has. For example, some Intemet apphances may be conflgm'ed without diskette drives, CD- 
ROMs, or DVD-ROMs. Because they are designed solely for Intemet access (i.e., web browsing and email), they 
may have less expensive components (e.g., less memory and smaller or no hard drives). 

The large numbers of people now spending time browsing the Intemet have encouraged merchants, service 
providers, and traditional retailers (collectively "retailers") to establish a presence on the Intemet. The low 

40 hardware cost of Intemet appliances is now allowing some retailers to provide customers with free Intemet 

appliances and Intemet access iri exchange for the right to control some aspects of the user's browsing experience. 
These controlled aspects may include the ability to display particular advertisements and branding information 
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while the user is browsiag and the ability to set the default web page that appears whenever the user first turns on 
the appliance or accesses the web (sometimes referred to as a "home page"). Next-generation Internet appliances 
may take this trend further by integrating browsers and Internet access functions into traditional appliances (e.g., 
refrigerators) that perform specific functions using the Internet (e.g., automatically ordering groceries). Thus, 
5 Internet appliances may require customized user interfaces specifically tailored to the particular application and the 
particular needs of end users. 

To implement these customized features, programmers have typically had to write new browser 
applications for each customization. While some software code may be reused, writing new code to change the 
appearance or functionaHty of the user interface is time consuming, expensive, and may require specialized 

10 expertise. For these reasons, there is a need for an improved method for customizing the user interface of browsers. 
Another particularly desirable feature for retailers interested in this market model is the ability to 
effectively force users to view advertisements. From the retailer's point of view, since they are paying for the 
hardware and software (and possibly the Internet connection), the retailer wants to ensure that the user views the 
advertisements. This is currently a problem because end-user applications are available to filter out banner 

15 advertisements. If an end user were to download and use one of the filtering plug-ins, the retailer's investment in 
the browser and appliance could be undermined. Similarly, it may be particularly advantageous for the retailer to 
control certain aspects of the user interface in addition to or in lieu of advertising. 

Yet another potentially desirable feature for retailers interested in advertising using the Ihtemet would be 
the ability to more accurately track consumer's responses to particular web pages and/or advertisements. As the 

20 amount spent on Intemet advertisement increases, demand for this feature may increase. 



Summary of the Invention 

The problems mentioned above are at least in part solved by a system and method that implements a 
customizable framework for a graphical user interface based on a configuration file storing information that is 

25 usable to generate a customized user interfece. The configuration file may be configured to be easily updateable via 
a remote server without any required interaction from the end user. In some embodunents, each end user may have 
their own customized configuration data set that may be automatically updated and may be based on personal 
information, user-specific browsing history, and/or user-specific appliance usage. Please note that as used herein, 
die terms "configuration file" and "configuration information" are used interchangeably. Configuration file is a 

30 broad term meant to encompass all data storage mechanisms capable of storing information for use in generating the 
graphical user interface. For example, one or more individual data arrays, strings, variables, memory locations, or 
traditional files within a directory structure may all be considered to fall within the definition of "configuration 
file" and "configuration information" as the terms are used herein. 

In one embodiment, the method may be embodied as a browser software program that is stored on a 

35 computer-readable medium (e.g., diskette, CD-ROM, DVD-ROM, tape, RAM, ROM). The browser may uiclude a 
plurality of instructions that are configured to access a configuration file upon start-up (e.g., power-up, application 
start, or user loghi). The configuration data set may include, inter alia, data defining a customized user interface 
appearance and functionality. The customized user interface may include one or more user interface objects (also 
referred to as controls or user interface elements), and the configuration data set may include specific data 

40 corresponding to each of the customized or customizable user interface objects. For example, an object may be a 
graphical icon or menu item that is Hnked to a particular function or web site. The browser may be configured to 
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use the mfomiation stored in the configuration file to generate and display a customized user interface on a display 
device. The browser may be further configured to monitor user iateraction with the user interface objects and 
respond to user interaction with the objects. For example, the browser may be configured to access a particular web 
page that is linked to a particular icon that the user has selected (i.e., clicked on). 
5 In some embodiments the browser may be configured to prompt the user for a password. The browser may 

then be configured to use this password to select a particular configuration from a number of different configuration 
files, wherein each different configuration file may correspond to a different user or user profile. Advantageously, 
this may allow the browser to efficiently support customized user iaterfaces for multiple users. The configuration 
file may contain pointers or links to graphics files that contain the data needed to generate icons and other visible 

10 and audio portions of the user interface. In some embodiments, multiple configuration files may share some or all 
of the graphics files. The configuration file may also include size and position information that is needed by the 
browser (or an underlying operating system) to position and render the visual information in the graphics files as 
part of the user interface. The configuration file may further uiclude linking urformation describing which 
functional modules (e.g.; accesses to a particular web page) should be invoked in response to a particular user 

15 interface object being selected by said user. 

In addition to position, size, and linking information for the graphics files, the configuration file may also 
include similar information necessary to invoke one or more browser plug-in modules (e.g., audio or digital video 
stream players). For example, one browser plug-in may be an electronic wallet module. The electronic wallet 
module may be passed information by the browser (or operating system) based on the information provided by the 

20 user when logging in (e.g., thus requiring the user to only enter their password once). In some embodiments, the 
configuration file may further include features such as a default home page address and default search engines that 
are also customizable and npdateable via a remote server. 

Advantageously, the use of the configuration file allows the browser to efficiently update the configuration 
file. For example, tiie browser may be configured to access a server on a periodic basis (e.g., at each power up, 

25 application start, log-in, or every hour) to update the configuration file. These updates may include updated linking 
information, new graphics files, new position and size information, and new plug-in modules and stand alone 
applications for additional functionality. The browser may be configured to wait until a predetermined idle state is 
reached before perfomiing an update. In some embodiments, the user may be locked out from modifying some or 
all of the information in the configuration file. Depending upon the implementation and security needs, one or 

30 more of the graphics files and/or configuration files may reside on a server instead of residing locally on the Internet 
appliance/computer system executing the browser application. In some embodiments, the browser may be 
configured to convey information to a predetermined server (or servers) about a user's actions while executing the 
browser, wherein the server is configured to update the browser's configuration file based on the information about 
the user's actions. Shnilarly, the server or servers may be configured to update the configuration file based on 

35 geographical information stored in the configuration file (e.g., the user's address) or provided by tlie end user. This 
may advantageously enable location-specific custoniized user interfaces. The update may be configured to support 
"checkpoints", which allow the update process to be restarted from a checkpoint instead of the beginning of the 
update in response to the intermption of the update process (e.g., to devote more resources to user activities). Since 
the update process may entail downloading entire new applications, supporting checkpoints may reduce the time 

40 needed to complete an intermpted update. In some embodiments, the data for the update is downloaded while the 
appliance or browser is in an idle mode, but the data may not be used to modify the configuration file (i.e.. 
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configuration infonnation) until the next time the browser or appliance is started up (e.g., after a sleep mode or 
power down). 

An Internet appliance configured to execute a customizable browser is also contemplated. In one 
embodiment the appliance may include a display device (e.g., an LCD panel), a user input device (e.g., a keyboard), 
5 a network communications device (e.g., a modem), and a memory (e.g., a flash memory) configured to store tlie 
browser application and the configuration file, and one or more processors configured to execute the browser 
application. The processors are configured to receive data from the input device, the network communications 
device, and the memory, and are configured to output data to the display device and the network conamunications 
device. The memory may store an operating system (e.g., Linux, a Windows variant, or other operating system), 
10 the browser program, and the user interface configuration file. The operating system may be configured to 

automatically execute tiie browser program (e.g., upon power up), and the browser program may be configured to 
automatically read the configuration file upon execution. As noted above, the browser may be configured to use the 
infonnation in the configuration file to define the appearance and functional attributes of a customized user 
interface for the browser. 

15 In some embodiments, the Intemet appHance may include additional hardware (e.g., a thumb or retinal 

scanner, or a microphone) which the browser may be configured to use to automatically select one of a plurality of 

configuration files. Advantageously, this may improve the speed of the login process and also improve security. 

These and other benefits and advantages of the present invention shall become apparent from the detailed 
description of the invention presented below hi conjunction with the figures accompanying the description. 

20 

Brief Description of the Drawings 

A better understanding of the present invention may be obtained when the following detailed description of 
the preferred embodiment is considered in conjunction with the following drawings, in which: 

Figure 1 is a network diagram of one embodiment of a wide area network which is suitable for 
25 implementing various embodiments; 

Figure 2 is an illustration of one embodiment of a typical computer system which is suitable for 
implementing various embodiments; 

Figure 2A is an illustration of one embodiment of an Internet appliance; 

Figure 3 is an illustration of one embodiment of a sample web browser user interface; 
30 Figure 4 is an illustration of another specific embodiment of a web browser user interface; 

Figure 5 is an illustration of yet another specific embodiment of a web browser user interface; 

Figure 6 is a block diagram illustrating one embodiment of a customizable firamework for a browser user 
interface; 

Figure 7 is a block diagram illustrating one embodiment of a configuration file usable to implement a 
35 customizable browser framework; 

Figure 8 is a flowchart of one embodiment of a method for generating a configuration file usable to 
implement a customizable browser framework; 

Figure 9 is a flowchart of one embodiment of a method for using the configuration file and customizable 
framework in a browser; and 
40 Figure 10 is a flowchart illustrating one method for storing data generated by browser users. 
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While the invention is susceptible to various modifications and alternative forms, specific embodiments 
thereof are shown by way of example in the drawings and will herein be described in detail It should be 
understood, however, tiiat the drawings and detailed description thereto are not intended to limit the invention to the 
particular form disclosed, but on the contrary, the uitention is to cover all modifications, equivalents and 
5 alternatives falling within the spirit and scope of the present invention as defined by the appended claims. Please 
also note that the headings used herein are for organizational purposes only and are not meant to have any effect on 
the interpretation of the claims or the detailed description. 

Detailed Description of Several Embodiments 

10 Before describing a number of different embodiments in greater detail, some information regarding 

networks, personal computers, and Intemet appliances is discussed 

Figure 1: wide area network 

Figure 1 illustrates one embodiment of a wide area network (WAN) 102. WAN 102 is a network that spans a 

1 5 relatively large geographical area. The Intemet is one example of a WAN. WAN 1 02 typically includes a pluraHty of 
con^uter systems wliich are interconnected through one or more networks. Although one particular configuration is 
shown in Figure 1, the WAN 102 may include a variety of heterogeneous computer systems and networks which are 
interconnected in a variety of ways and which run a variety of software applications. 
< One or more maiofirame computer systems 120 may also be coupled to WAN 102. As shown, mainframe 120 

20 may be coupled to a storage device or file server 124 and mainframe terminals 122a, 122b, and 122c. The mairrframe 
terminals 122a, 122b, and 122c may access data stored in the storage device or file server 124 coupled to or included in 
the mainframe computer system 120. WAN 102 may also include computer systems 112b, personal digital assistants 
(PDAs) 128, and Intemet appliances 126 and 113 (e.g., a refrigerator configured to order groceries using the Intemet) 
which are connected to WAN 102 individually. For example, WAN 102 may include computer systems which are 

25 geographically remote and connected to each other via the Intemet. 

One or more local area networks (LANs) 104 may be coupled to WAN 102. LAN 104 is a network that 
spans a relatively small area. Typically, a LAN 104 is confined to a single room, floor, building or group of 
buildings. Each node (i.e., individual computer system or device) on LAN 104 preferably has its own CPU with 
which it executes programs, and each node is also able to access data and devices anywhere on LAN 104. Thus 

30 LAN 104 allows many users to share devices (e.g., printers) as well as data stored on file servers. LAN 104 may be 
characterized by any of a variety of types of topology (i.e., the geometric arrangement of devices on the network), 
of protocols (i.e., the rules and encoding specifications for sending data, and whetlier the network uses a peer-to- 
peer or client^server architecture), and of transmission media (e.g., twisted-pair wire, coaxial cables, fiber optic 
cables, radio waves). 

35 LAN 104 typically includes a plurality of interconnected computer systems and optionally one or more 

other devices: for example, one or more workstations 1 10a, one or more personal computers 1 12a, one or more 
laptop or notebook computer systems 1 14, one or more server computer systems 116, and one or more network 
printers 118. As illustrated in Figure 1, LAN 104 may include one of each of computer systems 1 10a, 1 12a, 1 14, 
and 116, and one printer 118. LAN 104 may be coupled to other computer systems and/or other devices and/or 

40 other LANs 104 through the WAN 102. 
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Figure 2: typical computer system 

Figure 2 illustrates a typical computer system 150 which is suitable for implementing various 
embodiments of tiie system and method for creating a customizable browser as described in greater detail below. 
Computer system 150 typically iQcludes components such as a CPU 152 with an associated memory medium 160. 
5 The memory medium may store program instructions for computer programs, wherein the program instructions are 
executable by the CPU 152 (or more specifically, by die one or more processors within CPU 152). The computer 
system 150 may further include a display device such as a monitor 154 (e.g., a liquid crystal display or "LCD", a 
cathode ray tube display or "CRT", a head mounted display, or a projection display), an alphanumeric input device 
such as a keyboard 156, and a directional input device such as a mouse 158. Altematively, keyboard 156 and/or 
10 mouse 158 may be replaced or supplemented with a microphone and speech recognition hardware and/or software, 
a video camera, and/or a track pad. The computer system 150 may be operable to execute the computer programs 
to implement creation of a customizable framework for a browser to be used with the World Wide Web as 
described herein. 

The computer system 150 preferably iacludes memory medium 160 on which computer programs according to 

15 various embodiments may be stored. The terra "memory medium" is intended to iaclude an installation medium, e.g., a 
CD-ROM, or floppy disks, a computer system memory such as DRAM, SRAM, EDO RAM, Rambus RAM, etc., or a 
non-volatile memory such as a magnetic media, e.g., a hard drive, or optical storage. The memory medium may include 
other types of memory as well, or combinations thereof. In addition, the memory medium may be located in a first 
computer in which the programs are executed, or may be located in a second different conqjuter which connects to the 

20 jBrst computer over a network. In the latter instance, the second compiter provides the program instmctions to the first 
coinputer for execution. Also, the computer system 150 may take various forms, including a traditional personal 
computer system, an Internet appliance as previously discussed, a mainframe computer system, a workstation, personal 
digital assistant (PDA), television system or otlier device. In general, the term "computer system'* may be broadly 
defined to encon^ass any device having a processor which executes instmctions from a memory medium. 

25 The memory medium preferably stores a software program or programs for creating a customizable 

framework for a browser as described herem. The software program(s) may be implemented in any of various 
ways, mcluding procedure-based techniques, component-based techniques, and/or object-oriented teclmiques, 
among others. For example, the software program may be implemented usmg ActiveX controls, C++ objects, 
JavaBeans, Microsoft Foundation Classes (MFC), Java, traditional programs, or other technologies or 

30 methodologies, as desired. A CPU, such as the host CPU 152, executing code and data from the memory medium 
includes a means for creating and executing the software program or programs according to the methods and/or 
block diagrams described below. 

Figure 2A: sample Internet appliance 

35 Figure 2A illustrates one embodiment of an Internet appliance 180. In this embodiment, Internet appliance 

1 80 is an iBrow™ brand Intemet Appliance firom Merinta Corporation. Appliance 1 80 may comprise display 
device 154 (e.g., a 10" LCD display), CPU 152, and keyboard 156. In some embodiments, keyboard 156 maybe 
wireless (e.g., infrared) and may include an integrated pointing devices such as a track ball, mouse, or joystick. 
Appliance 180 may also comprise speakers 170A-B, and a video camera 172. In some embodiments, appliance 180 

40 may further comprise indicators 174 and additional buttons (e.g., power button 176). While each configuration may 
vary, in one embodiment CPU 152 may comprise one or more universal serial bus connectors, a 56k v.90 intemal 
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modem, a microphone input, and amplified headphone output. CPU 152 may also be configured with an external 
volume control, external contrast control, an AC power adapter, dixal RJ-1 1 phone jacks for line-iti and telephone- 
out, and both flash memory and SDRAM (synchronous dynamic random access memory). Indicators 174 may be 
configured to inform users of power up status or other information. 
5 Other optional hardware may be included with Intemet appliance 180, for example, a bar code scanner (for 

user identification and product identification), a smart card reader (for user identification), a Java™ ring interface 
(for user identification), camera (for user identification and for video conferenciug), a retinal scanner (for user 
identification), a thumb print scanner (for user identification), a microphone (for voice recognition and speech 
recognition), or a voice synthesizer (for text-to-speech). 

10 

Figure 3: sample web browser user interface 

Figure 3 illustrates one embodiment of a web browser user interface 300. At the top of the web browser 
user interface 300, several toolbars are represented: a sizing toolbar 303, a title bar 304, a navigation toolbar 305, a 
URL toolbar 306, and a persistent portal 307. Below the persistent portal 307, a main content section 301 is shown. 

1 5 Scroll bars 302A-B may be found to the right and also below the main content section 301. At the bottom of the 

web browser user mterface 300, additional toolbars are represented: a status toolbar 308 and a live feed toolbar 309. 
To the right of the status toolbar 308 and the live feed toolbar 309, an advertisement 310 is shown. Note, 
advertisement 310 may be configured to display a different image periodically (e.g., a new image every 15 seconds 
or every 0.10 seconds). This allows animation within the advertisement and allows different advertisements to be 

20 displayed to the end user. Logo bar 3 12 may be implemented to display a retailer's or manufacturer's logo. Logo 
bar 312 may also be animated. Depending upon the exact implementation, logo bar 3 12 may also be persistent, i.e., 
ever-present regardless of what tiie user is doing, which page the user is browsing, and regardless of which 
applications the user is executing. 

Elements of the sizing toolbar 303 may include, for example, a logo, a minimize button, a maximize 

25 button, and a close button (not shown). The title bar 304 may include the name of the browser, the name of a web 
page currently being viewed, or the name of a sponsor of the web browser (not shown). Elements of the navigation 
toolbar 305 may include a back button, a forward button, a stop button, a reload button, a home button, a print 
button, a font button, a window button, a help button, a favorites button, a search button, and an e-mail button (not 
shown). The URL toolbar 306 may include an entry box into which a user may enter a URL address, and a GO 

30 button to load the entered URL address (not shown). Elements of the persistent portal 307 may include labeled 
buttons, tabs, or other links, along with a logo of the sponsor of the web browser (not shown). 

The main content section 301 displays the contents of web pages and may change based on the choice of 
button that the user selects (i.e., from the navigation toolbar 305 or from the persistent portal 307) or based on the 
URL address that the user enters in the URL toolbar 306. 

35 The scroll bars 302A-B allow the user to view consecutive lines of data on the display screen, both 

vertically and horizontally. As used herein, "scroll" means that once the screen is full, each new line appears at the 
edge of the screen and all other lines move over one position. For example, when you scroll down, each new line 
appears at the bottom of the screen and all the other lines move up one row, so that the top line disappears. Vertical 
scrolling refers to the ability to scroll up or down. Horizontal scroUing refers to the ability to scroll left or right. 
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The status toolbar 308 may be configured to indicate the current status of the browser. For example, status 
toolbar 308 may indicated what percentage of the current page has been received across the network connection 
(e.g., "50% coniplete) or the address that is currently being accessed (e.g., connectiag to "www. merinta.com. . ."). 

The live feed toolbar 309 may be configured to display data that is periodically updated Exan^les of 
5 content that may be displayed in the live feed toolbar 309 includes a stock ticker, sports scores, and news headlines. 
This content may be automatically updated on a periodic basis (e.g., every five minutes). Please note that other 
types of toolbars, portals, and content areas may also be implemented using the customizable framework disclosed 
herein. The examples cited herein are merely for illustrative purposes and are not meant to be limiting. 

The advertisement 310 may be a banner advertisement that links to a particular web page when the 
10 advertisement area is clicked on by the user. The banner advertisement may be aniioated to attract the viewer's 
iQterest, and the advertisement may change periodically (e.g., once every minute) or based on the user's browsing 
activity. 

Specific examples of the various elements of sample browser user interfaces 300 are shown in Figures 4 

and 5. 

15 

Figures 4-5: specific browser user iuterface embodiments 

Figure 4 illustrates a specific embodiment of web browser user interface 300, Figure 5 illustrates another 
specific embodiment of web browser user interface 300. As these figures illustrate, the visual appearance of user 
interface 300 may change dramatically based on the different customizations made. Examples include the different 

20 organization of icons, different positions for the toolbars, dififerent fonts, and different titles in title bars 304. 

In addition to changing the visual appearance of user interface 300, functional changes may also be 
implemented. For example, the web pages linked to the different icons in persistent portal 307 may be customized. 
A bank providing an Internet appliance to its customers may wish to have links as illustrated in Figure 4 (e.g., to 
pages that perform electronic bill payment, loan application pages, or account information), while a retailer such as 

25 Amazon.com may wish to have links as illustrated in Figure 5 (e.g., to pages that sell music and videos, books, and 
travel reservations). In some embodiments, one or more of the toolbars such as persistent portal 307 may be fixed 
(i.e., the user cannot change, hide, or close the toolbars). In other embodiments, users maybe allowed to move the 
toolbars aroimd, resize them, or even hide them. In some embodiments users may also be allowed to select the 
icons and the web pages to which tlie icons link. 

30 

Figure 6: customizable browser framework embodiment 

Tuming now to Figure 6, a block diagram illustrating one embodiment of a framework for a customizable 
browser is shown. As the figure illustrates, a user interface construction application 400 is used to generate one or 
more configuration files 402A~402B, These configuration files store, inter alia, ioformation on linking, position, 

35 size, color, geometry, graphic image, behavior, associated applications, and fonts. This information is useable by 
web browser 410 to generate a customized user interface. The configuration files 402A-402B may include lioking 
and position information for one or more graphics files 404A-404B, one or more third party modules 406, and one 
or more Internet appliance software applications 408. Advantageously, web browser 410 may be configured to 
access one or more configuration files 402A-402B to generate a customized user interface. As shown in the Figure, 

40 web browser 410 is also configured to interact with operating system 412, which is responsible for managing and 
interfacing with the hardware of the computer (or Internet appliance). 
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In some embodiments, user interface construction application 400 may be configured as a stand alone 
software application that is configured to operate on a computer system (e.g., a personal computer). In other 
embodiments, user interface construction application 400 may be bundled with web browser 410 as a restricted 
access feature available only to users with certain access privileges. User interface CQnstruction application 400 
5 may be configured with its own graphical user interface that allows user interface designers the ability to "drag-and- 
drop" icons or graphical images representing different user interface features to generate a user interface layout for 
web browser 410. User interface construction application 400 may then be configured to store the customized user 
interface information into one or more configuration files 402A-402B. In some embodiments, conjagiiration files 
402A-402B may actually include the graphical information used to generate the icons and images that are 

10 incorporated as part of tihe customized user interface. However, m other embodiments (as shown in Figure 6) 

configuration files 402A-402B may merely include links (e.g., file name references or pointers) to tihe appropriate 
icon and/or graphics files 404A-4G4B. Configuration files 402A-402B may also include subroutines or objects that 
call third party modules 406. Examples of these third party modules include streaming video clip players, 
streaming audio players, three-dimensional graphics decompression software, encryption software and electronic 

15 wallet modules. Configuration files 402A-B may fhxther include software that calls, executes or invokes additional 
software applications 408, Some possible examples of such additional Intemet appliance software applications 
include email programs, chat programs, calculator programs, word processors, news readers, telephone and video 
phone applications, and computer games. For example, the user interface construction application 400 may link a 
particular icon that is configured to invoke an email composition application in response to the user clicking on the 

20 particular icon. In some embodiments, configuration files 402A-B may also include links to particular functions 
within operating system 412. For example, in some customized user interfaces, a particular icon in the gr^hics 
user interface for web browser 410 may be linked to a power down or sleep function implemented within operating 
system 4 12. 

Advantageously, each configuration file 402A-402B may be linked to one or more particular users or user 
25 profiles. For example, web browser 410 and/or operating system 412 may be configured to prompt the user for a 
password or user name. Web browser 410 may be configured to use this information to select a particular 
configuration file corresponding to that user name or password. As previously noted, the customizable framework 
illustrated in Figure 6 may be used within a browser configured to be executed on a personal computer or on an 
Intemet appliance. Please note that Figure 6 merely illustrates one possible embodiment for this customizable 
30 framework. As those skilled in that art will appreciate, additional features may be incorporated iato this framework. 
For example, graphics files 404A-404B may be supplemented by audio files that are configured to play customized 
audio clips or sounds in response to particular user actions. 

Figure 7: configiu:ation file embodiment 

35 Turning now to Figure 7, one embodiment of configuration file 402A is shown. In this embodiment, 

configuration file 402A comprises a pluraUty of different types of information including corresponding 
password/user id information 420. This information may be used by the web browser or operating system to select 
which particular configuration file will be used for a particular user. In some embodiments, a particular 
configuration file may be designated as the default configuration file for any new users that do not have a password 

40 or user id. This information may also be stored with the corresponding password/user id tnfomiation 420. 

Configuration file 402A may also comprise general user interface information 422. Examples of this type of 



9 



wo 01/67285 PCT/USOl/06834 

information may include the number of tool bars to be displayed, and whether or not the tool bars may be used by 
the user or hidden by the user. Configuration file 402A may also comprise specific informatiou for each tool bar to 
be displayed. For example, configuration file 402A may include title bar information 424 that describes position 
and function information about the title bar (see item 304 in Figure 3). Title bar information 424 may include 
5 position information 426 (including minimum and maximum X and Y coordinates in screen pixels), color 

information 428, font information 430 (including t3rpeface, font size, font attributes such as underlining, and font 
color), and information usable to link to a graphics file 432. The graphics file link information may be used to 
display an image (e.g., a logo) on the title bar. Note, the information described in the Figure is merely for 
explanatory purposes, and additional information may be included according to a particular embodiment For 
10 example, links to graphics file information 432 may further include position information and gamma correction 
information. 

As the Figure illustrates, configuration file 402A may also include information for an options tool bar (or 
persistent portal) 434. In addition to the position, color, font, and graphics file information (as described in 
comection with title bar information 424), icon-specific information may also be included. For example, 

15 information corresponding to a first icon 436 may also be included. In addition to the position, color, font, and 

graphics file information for the icon, a link or link information describing one or more associated web pages may 
also be included (see item 440). In some embodiments, as previously noted, a second set of information for a 
second icon 438 may include link information to the operating system (see item 442 in the figure). This 
information may be used to invoke an operating system function such as powering down the computer or Internet 

20 appliance. An arbitrary number of additional sets of information may also be included. Furthemiore, additional 

information for each icon or control may also be included. For exan^le, the icons may support mouse-over or roll- 
over effects (e.g., changing appearance in response to the cursor moving over the icon) or animation. In another 
embodiment, each icon may comprise multiple imageS:, and one of the multiple images is selected in response to a 
particular user logging on. For example, there may be a large and a small set of icons, wherein the small set of 

25 icons are used to maximize the size of the main content area 450, while the larger set may be more suitable for users 
that have difficulty seeing smaller icons. 

Configuration file 402A may also include information regarding the content area (see item 450 in the 
Figure), information regarding advertisements to be displayed (see item 460 in the Figure), and live feed tool bar 
information 470. In some embodiments, the advertisement information 460 and/or the live feed tool bar 

30 information 470 may include links to one or more web servers for content and advertisements (see items 462 and 
472, respectively, in the Figure). 

As previously noted, configuration file 402A may further include information necessary to invoke one or 
more plug-ins 480. This information may vary depending upon the plug-in being invoked, e.g., position 
information. As described in greater detail below, some embodiments of web browser 410 may be configured to 

35 store information regarding users' activities while the browser is executing. In some embodiments, configuration 
file 402A may include such data, or may include a pointer to a data file generated using such data (see item 490 in 
the Figure). In yet other embodiments, a plurality of pointers 490 may be included to data files with different types 
of user information stored therein. 

Advantageously, in some embodiments the configuration file may be used to indicate to the browser which 

40 elements of the user interface should remain constant regardless of the user's actions. For example, in some 

embodiments persistent portal 434 may be configured to remain on the display device regardless of which content 
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the user is viewing. As noted in the Description of the Related Art section of the application, this may be a 
particularly useful feature for retailers seeking to generate high traffic volumes for e-commerce web sites. The 
example user interface of Figure 5 illustrated a series of icons in the persistent portal labeled "Clothing", 
"Banking", "Health", 'TSTews", "Music", "Movies", and "Food". As the names of these icons indicates, each icon 
5 may be linked to a particular e-comtnerce or advertisuig site. Advantageously, the retailer that provided the 

customized browser (and possibly the Intemet appliance) may configure each icon to link to a particular site of the 
retailer's choice (e.g., the retailer's own web pages or the web pages of a third party that has agreed to pay the 
retailer a commission based on the volume generated by the persistent portal links). In some embodiments, 
persistent portal 434 may be configured such that the user is prevented &om obscuring the portal with any windows. 

10 For example, Ifae user interface may be configured with a pop-up calculator that may be dragged around the screen. 
However, the user iaterfacc may be configured such that the calculator may not be dragged over the region that 
defines the persistent portal. This may be a desirable feature for some retailers. Similarly, the user iaterface may be 
configured to prevent users from obscuring other toolbars, e.g., advertisement bar 310. 

Unlike traditional browsers, the persistent portal may be displayed regardless of what function the user is 

15 performing (e.g., drafting an email message), and may be configured to change periodically as updated by a server 
(e.g., the server may update the browser's configuration file automatically). In some embodiments, as described in 
greater detail below, the browser may be configured to send usage information (e.g., information about which web 
pages were visited, for how long, content information, information about which parts of the screen the user's cursor 
is on or travels across, user presence information, scrolling behavior, etc.) back to the advertisement server or to 

20 another server (e.g., one operated by tihe retailer or browser developer). The server may then be configured to 

analyze the data to deteimine usage patterns and then change the configuration of the persistent portal to have links 
that better target tiie user's interests. As with other customization information stored in the configuration file, the 
configuration information for the persistent portal may be customized on a per-user basis. Thus, if an Intemet 
appliance is used by an entire family, the persistent portal for the mother may include links that reflect the mother's 

25 interest. For example, the "Clothing" icon may display a woman's outfit and may be linked to a retailer of 

women's clotliing. Similarly, when the father logs onto the appliance, the same icon in the persistent portal may 
change to display a "Golf icon comprising a golf ball, and the icon may be linked to a golfing retailer's web site 
based on the father's frequent visits to golf web pages. Similarly, for a child the persistent portal icon may be 
linked to an auction site for comic books. 

30 In some embodiments, the configuration file may also include geographical information about the user 

and/or the Intemet appliance. For example, the configuration file may include the city and state and/or the street 
address of the user. The server may then be configured to customize the content of the persistent portal (or other 
non-persistent portions of the user interface) based on tlie geographic location of the user. Thus a "Restaurant" Hnk 
may be linked to web pages for local restaurants that are near the user. 

35 In some embodiments the configuration file may be stored in the Intemet appliance's memory (e.g., in 

RAM, flash memory, or in a hard drive). In other embodhnents the configuration file may be stored on a server 
which the browser accesses upon logui or power-iip. 

Additional information may also be stored in the configuration file, depending upon the exact 
implementation. For example, if an Intemet appliance is configured to be used in the lobby of a baiik, the 

40 configuration file may be configured to limit the viewable web pages to a predetermined domain stored in the 

configuration file (e.g., the bank's domain). Similarly, the configuration file may contain information directing the 
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browser to limit the viewable pages to a predetermined set of domains (e.g., ones approved by the bank) or to a 
predetermined set of web pages stored on a specific server. These limitations on which web pages the browser may 
access may be particularly useful if the sponsor of the Internet appliance (i.e., the retailer in the previous examples) 
desires to censor certain content (e.g., pornography or a competitor's web sites). Sinoilarly, the configuration fQe 
5 may indicate that the user iaput field in which users normally enter URLs (i.e., web page addresses) should not be 
displayed. This limits the possible displayable web pages to only those pages that are directly linked to icons or 
menu entries in the customized user interface. This may once again be useful in the bank lobby scenario. 

In other embodiments, additional information may be included as part of the configuration information. 
For example, information for cursor effects, overall "look-and-feel" of the interface, icon rollover effects, button 
10 press effects, and language information (e.g., is the user a native English or Spanish speaker). 

Figure 8: generating the coixfiguration file 

Turning now to Figure 8, one embodiment of a method for generating a configuration file usable in a 
customizable browser framework is shown. Figure 8 illustrates a flowchart depicting one embodiment of user 

15 interface constmction application 400 (also referred to herein as the "design program"). First, a user interface 
designer executes the design program or user interface construction application 400 (step 510). The design 
program may be configured to generate a default configuration file based upon one or more default selections (step 
512). For example, the default configuration file may include a standard user interface with a title bar but without 
any advertising spaces or third party plug-ins. 

20 Next, the design program may be configured to wait until a particular user interface element is selected 

(step 514). For example, the designer may be presented with a palette of different user interface elements from 
which to select. Next, the design program may be configured to prompt the designer for the name of a 
corresponding graphics file which stores an image to be displayed as the icon (step 516). Next, the design program 
may be configured to prompt the designer for the size (e.g., in pixels) of the icon or element (step 518). Next, the 

25 design program may be configured to prompt tiie designer to select a location for the icon or element (step 520). 
For example, the user may be presented with an image of the user interface being designed and the user may be 
allowed to "drag-and-drop" the icon to a particular position. 

If the new icon/element can be activated (e.g., selected) by the browser user (step 522), then the design 
program may be configured to prompt the designer for an action to be linked to the users selection or activation of 

30 the element (step 524), For example, the designer may select the power down function or the designer may select a 
particular web page address to be linked in response to the user's selection or activation of the element. If, 
however, the element is merely for aesthetic pinposes, then step 524 may be bypassed. 

If the element is tied to a plug-in (step 526), then the design program may be configured to prompt the 
designer to select one or more plug-ins and one or more corresponding messages to generate upon activation (step 

35 528). For example, the browser and/or operating system may be configured to use "messaging" to invoke a certain 
plug-in or a selected action. However, if the element or icon is not tied to a plug-in, this step 528 may be bypassed. 
This process for configuring selected user interface elements may be repeated a number of times (step 532) until the 
designer has configured all of the user interface elements that were selected. The design program also may be 
configured to prompt the designer to select one or more additional plug-in modules for incorporation into the 

40 customized user interface, and it may prompt the designer to specify position information for any visible aspects of 
the selected plug-in modules. 
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The design program may also be configured to prompt the designer for a default home page address (step 
534) and for oflier attributes (step 536). For exan^le, the design program may prompt the designer to enter the 
interval at which a particular displayed web page, advertisement, or frame is updated (e.g., for a stock ticker). Once 
all of the selected information is completed, the design program may be configured to store the information into a 
5 configuration file that is accessible by web browser 410 (step 538). This process may be repeated for each different 
profile (step 540). As previously noted, the design program may be configured to prompt the designer for a 
password or user id which may be used to correlate the completed configuration file with a particular user. 

While a custom program for interactively generating the graphical user interface and configuration file are 
preferred, a more simple approach may be to utilize an editor program (e.g., an XML editor) to create and edit the 
10 configuration file. Other types of graphical user interface tool kits may also be used in some embodiments. 

Figure 9: using the configuration file 

Turning now to Figure 9, a flowchart of one method for implementing a customizable browser framework 
and for using a previously generated configuration file is shown. In this embodiment, in response to the user first 

15 powering up the Internet appliance (step 600), the operating system boots (step 602) and prompts the user for a log 
in or a password (step 604). The operating system then begins execution of the browser and passes the browser the 
appropriate user profile information (step 606). The browser is then configured to read the configuration file that 
corresponds to the log in information or password (step 608). Next, the browser accesses and uses the graphics files 
pointed to by the configuration file (step 610). The browser may also be configured to read executable information 

20 firom plug-ins pointed to by configuration file (step 612). The browser may then be configured to use this 

information to display the user iaterface (step 614). As noted above, the browser may be configured to further read 
the address of a default home page and display this together with the customized user mterface (step 614), as 
specified by the configuration file. As noted above, the layout, visual appearance, and functionality of the browsers 
user interface may be dictated by the configuration file. Once the user interface is displayed, the browser may 

25 operate in a normal manner by displaying web pages that are selected by the user (step 615). In response to the 

browser and/or operating system entering into a predefined "idle" state (step 616), and if sufficient time has passed 
since a previous update, or if there is an update available on a specified update server (step 618), the browser may 
be configured to automatically contact the update server and download hiformation to update the browser. This 
information may include, but is not limited to, one or more of the following: the graphics files, the configuration 

30 files, browser plug-ins, the operating system, other applications, and the apphcation browser itself (step 620). In 
some embodiments, the browser may be configured to automatically check a specific update server at each power 
up. Furthermore, in some embodunents, the browser may be configured to upload usage information while in the 
"idle" state (step 622). For example, this usage information may include web pages the user has visited, the amount 
of time the browser has been active, cursor movement information in response to particular web pages and/or 

35 advertisements, login information for each of the different user profiles, and other information. While the definition 
of "idle" state may vary on an embodiment by embodiment basis, generally an idle state may be declared if a 
predetermined amount of time has elapsed since the browser has received any user input (e.g., a cursor movement 
or key stroke) or received data from a server. 

In yet other embodunents, the browser may also be configured to update cached web pages (e.g., based on 

40 the configuration file information) to speed browsing of pages that are likely to be viewed (step 624). For example, 
the configmration file may include information listing the five most commonly accessed web pages for the user. 
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The browser may then be configured to access these web pages and download their content periodically during idle 
periods (e.g., once per hour). Advantageously, this may speed upthe browsers performance and reduce latency 
when the user selects a particular commonly accessed web page. 



5 Figure 10: storing information generated by the browser user 

Turning now to Figure 10, one embodiment of a method for storing data based on a user's browsing 
activities is shown. In one embodiment, ia response to the user logging on to the appliance or browser (step 650), 
the browser is configured to use the login information to read a corresponding conjSguration file (step 652). As 
previously described, the browser is configured to generate a corresponding user interface (step 654). The browser 
10 may be configured to determine whether or not the accessed profile is configured to allow tracking of the user's 

browsing activities (step 656). In some embodiments, some user profiles and corresponding configuration files may 
be configured to prevent the browser from tracking the user's browsing activities (step 657). This may be 
particularly advantageous when multiple users are using the browser, or when a particular user desires privacy for 
their browsing activities. 

15 If, however, the user profile allows tracking (or the user consents to tracking via a "click-through" 

agreement), then the web page address of each loaded web page may be stored (step 658). Additional information 
may also be stored, e.g., the time fiom the start of load to the completion of loading of tlie web page (step 660), 
Examples of other types of inforaiation that may be stored include the time j&:om the completion of a web page load 
until the user performs a predetermined action (e.g., movement of the cursor, a mouse click, or a key stroke) (step 

20 662). Similarly, the location of the user action (e.g., mouse click) and the type of action may be stored (step 664). 
After a predetermined amount of tune and after the browser is in its idle state (step 668), the web browser may be 
configured to process the data (step 670). Examples of processing the data may include compressing the data or 
compiling statistics based on the data (step 670). The processed data may then be transmitted to a predetermined 
data server (step 672). Advantageously, this configuration may allow a browser vendor to store usage information 

25 garnered fiom a large number of browser users* This usage information may be particularly valuable (e.g., it may 
be sold to advertisers). 

Please note that although the flowcharts in the figures are detailed, they are meant for explanatory purposes 
only and that additional steps may be added or that steps may be combined or performed in a different sequence, 
depending upon the exact implementation. 

30 In some embodiments, the browser may be configured to signal a predetermined server in response to the 

user either logging in or accessing a particular web site. The server may then be configured to send an indication to 
a telemarketing firm that the user is at home. The telemarketing firm may thus avoid the wasted time spent calling 
people that are not home. The telemarketing firm may then call, email, or send an instant message to the user. For 
users that only have one traditional phone line for computer and voice (i.e., instead of a DSL or cable modem 

35 configuration), the browser may be configured to send a signal to the server before disconnecting, thus allowing the 
server to inform the telemarketing firm that the user just disconnected from the Intemet. Advantageously, the user 
should stiU be at home and the phone line should be available for a call. A similar configuration could be used for 
providing follow-up calls to users that have browsed certain web pages. For example, if the user browsed an 
automobile manufacturer's web site or a listing of homes for sale, the server may be configured to signal the 

40 appropriate realty agency or automobile company so that they may call the user while the user is browsing or 
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immediately thereafter. This may be useful for performing web satisfaction surveys while the web browsing 
experience is still fresh in the user's mind. 

Although the system and method of the present iavention have been described in coimection with several 
embodhnents, the iavention is not intended to be limited to the specific forms set forth herein, but on the contrary, it 
5 is intended to cover such alternatives, modifications, and equivalents as may be reasonably iacluded within the 
spirit and scope of the iavention as defined by the appended claims. 
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1 . A method for generating a customized persistent presence in a graphical user interface, said method 
comprising: 

5 displaying a graphical user interface, wherein said graphical user interface comprises a first region defined as a 

persistent portal; 

displaying one or more user interface objects in the persistent portal; 

preventing users, other applications, and operating systems fi:om closing, obscuring, or changing the one or more 
user interface objects and the persistent portal; 
10 storing information about user interaction with the graphical user interface; and 

automatically changmg the user interface objects in the persistent portal based on the stored information. 

2. The method as recited in claim 1 , further comprising: 

determining the identity of a user using interacting with the graphical user interface, and 
15 selecting the user interface objects to display in the persistent portal from a plurality of different user interface 
objects based on the identity of the user. 

3 . The method as recited in claim 1 , further comprising: 

determining the identity of a user using interacting with the graphical user interface, 
20 monitoring the content accessed by the user, and 

selecting the user interface objects to display in the persistent portal from a plurality of different user interface 
objects based on the identity of the user and the content accessed by the user. 

4. The method as recited in claim 1, wherein said determining is performed by one or more of the following: 
25 fingerprint matching, voiceprint matching, retina scanning, magnetic card reading, smart card reading, Java 

ring identification, or bar code scanning. 

5. The method as recited in claim 1, wherein said storing is performed individuaEy on a per-user basis. 

30 6. The method as recited in claim 1, wherein said method further comprises: 

using the browser to automatically store web page or application addresses viewed by users and corresponding view 
time mformation, and 

updating the visible icons and linked predetermined web pages or applications based on the information stored by 
the browser. 

35 

7, The method as recited in claim 6, wherein the information stored by the browser includes view time based on 
cursor movement and keystrokes. 

8. The method as recited in claim 1, wherein said method further comprises using the browser to access a server, 
40 wherein said generating comprises reading the one or more visible icons irom the server. 
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9. The method as recited in claim 1, wherein said method fnrther comprises changing the visible icons and liiiked 
predetermined web pages or applications in response to historical iateraction information stored by the 
browser, wherein the historical interaction information is updated based on user interaction with the browser 
user interface. 

5 

10. The method as recited in claim 1, wherein, said method further comprises changing the visible icons and linked 
predetermined web pages or applications in response to one or more of the following: (a) historical interaction 
information stored by the browser, wherein the historical interaction information is updated based on content 
displayed by the browser, (b) browsiug information stored by the browser, wherem the browsing information is 

1 0 updated based on the browsing history of the user. 

1 1. The method as recited in claim 1, wherein said method further comprises: 

using the browser to automatically store web page or application summaries viewed by users and corresponding 
view time information, and 

15 updating the visible icons and linked predetermined web pages or applications based on die information stored by 
the browser. 

12. The method as recited in claim 1, further comprising: 
prompting the user for a password; and 

20 selecting the one or more visible icons and corresponding links based on a user profile corresponding to the 
password. 

13. The method as recited in claim 12, further comprising: 

storhig a plurality of user profiles, wherein each user profile corresponds to a particular password, and wherein each 
25 user profile comprises user attribute information. 

14. The method as recited in claim 13, further comprising storing a pluraHty of user profiles, wherein the user 
attribute information includes the geographical location of the user. 

30 15. A computer program embodied on a computer-readable medium, wherein the computer program is configured 
to implement the method of any of claims 1- 14.. 

1 6. An Internet appliance comprising: 
a display device; 
35 a user input device; 

a network communications device; 
a memory; and 

a processor configured to receive data from said input device, said network device, and said memory, and 
configured to output data to said display device and said network communications device, wherein said 
40 memory is loaded with: 
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an operating system, 
a browser program, and 

a configuration file comprising information usable to generate one or more visible icons, wherein the 
browser program is configured to: 
5 access said configuration file; 

display said visible icons as part of a browser user interface, wherein said visible icons are 

displayed outside any web page content display areas of said browser user iaterface; 
link a predetermined web page to each of said one more visible icons, and 
prevent users firom closing, hiding or changing said one or more visible icons. 

10 

17. The appliance as recited in claim 16, wherein said browser is further configured to access a server and read the 
one or more visible icons from tlie server, wherein said browser is further configured to change the visible 
icons and linked predetermined web pages in response to browsing information stored by the browser, wherein 
the browsing information is updated based on the actions of the user. 

15 

18. The appliance as recited in claim 16, wherein said browser is further configured to change the visible icons and 
linked predetermined web pages in response to browsing information stored by the browser, wherein the 
browsing information is updated based on the browsing history of the user. 

20 19, The appliance as recited in claim 16, wherein said browser is further configured to automatically store web 

page or application addresses viewed by users and corresponding view time information, and update the visible 
icons and linked predetermined web pages based on the information stored by the browser. 

20. The appliance as recited in claim 16, wherein said browser is further configured to automatically store web 
25 page content types viewed by users and conesponding view time information, and update the visible icons and 

linked predetermined web pages based on the information stored by the browser. 

21 . The appliance as recited in claim 16, wherein said browser is further configured to automatically store web 
page summaries viewed by users and corresponding view time information, and update the visible icons and 

30 linked predetermined web pages based on the information stored by the browser. 

22. The appliance as recited in claim 19, wherein the information stored by the browser includes view time based 
on cursor movement and keystrokes. 

35 23 . The appliance as recited in claim 1 6, wherein said browser is further configured to prompt the user for a 
password, and select the one or more visible icons and corresponding links based on the password. 

24. The appHance as recited in claim 16, wherein said memory is further configured to 
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store a plurality of user profiles, wherein each user profile includes the geographical location of each corresponding 
user, wherein said appliance is further configured to customize the visual icons for each user based on the 
geographical location of each user. 

25. A computer-readable medium comprising a browser software program and a configuration file, wherein said 
browser software program comprises a plurality of instructions configured to: 

access said configuration file; 

display said visible icons as part of a browser user interface, wherein said visible icons are displayed 

outside any web page content display areas of said browser user interface; 
link a predetermined web page or application to each of said one more visible icons, and 
prevent users from closing, hiding or changing said one or more visible icons. 

26. The medium as recited in claim 25, wherein said browser is further configured to access a server and read the 
one or more visible icons from the server. 

27. The medium as recited in claim 25, wherein said browser is further configured to change the visible icons and 
Imked predetermined web pages ia response to browsing information stored by the browser, wherein the 
browsing information is updated based on the actions of the user, 

28. Tlie medixmi as recited in claim 25, wherein said browser is further configured to change the visible icons and 
Imked predetermined web pages or applications in response to browsing infomiation stored by the browser, 
wherein the browsing information is updated based on the browsing history of die user. 

29. The medium as recited in claim 25, wherein said browser is further configured to automatically store web page 
addresses viewed by users and corresponding view time information, and update the visible icons and linked 
predetermined web pages or applications based on the information stored by the browser. 

30. The medium as recited in claim 29, wherein the information stored by the browser includes view time based on 
cursor movement and keystrokes. 

3 1 . The medium as recited ia claim 25, wherein said browser is further configured to prompt the user for a 
password, and select the one or more visible icons and corresponding links based on the password, 

32. The medium as recited ia claim 25, wherein said browser is further configured to store geographical 
information for each user, and wherein said browser is configured to customize the one or more visible icons 
and corresponding links on a per-user basis based on the particular user's corresponding geographical 
information. 
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